<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      body {
        margin: 0;
      }

      #dgg {
        margin: 100px;
        position: relative;
        width: 200px;
        height: 200px;
        border: 1px solid red;
      }
      #dgg #jgg {
        width: 100px;
        height: 100px;
        border: 1px solid green;
        margin: 50px 0 0 20px;
      }
    </style>
    <script src="../jquery.min.js"></script>
    <script>
      $(function () {
        // jq 的 offset 就是以文档为基准的
        // 这个即可获取，也可设置
        $('#dgg').offset()
        $('#dgg > #jgg').offset()
        // $('#dgg > #jgg').offset({ left: 50, top: 50 })
        // 原生的 offset 是以第一个有定位的上层节点为基准的
        document.querySelector('#jgg').offsetLeft
        document.querySelector('#jgg').offsetTop

        // position 就是拿 top 和 left 的定位偏移，不包含 margin
        // 注意：该方法只能获取，不能设置
        $('#dgg').position()
        $('#dgg > #jgg').position()
      })
    </script>
  </head>
  <body>
    <div id="dgg">
      <div id="jgg"></div>
    </div>
  </body>
</html>
